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Sanksi Pelanggaran Pasal 113 
Undang-Undang Nomor 28 Tahun 2014 
tentang Hak Cipta 


1. Setiap Orang yang dengan tanpa hak melakukan pelanggaran hak ekonomi 
sebagaimana dimaksud dalam Pasal 9 ayat (1) huruf i untuk Penggunaan Secara 
Komersial dipidana dengan pidana penjara paling lama 1 (satu) tahun dan/atau 
pidana denda paling banyak Rp100.000.000 (seratus juta rupiah). 


Setiap Orang yang dengan tanpa hak dan/atau tanpa izin Pencipta atau pemegang 
Hak Cipta melakukan pelanggaran hak ekonomi Pencipta sebagaimana dimaksud 
dalam Pasal 9 ayat (1) huruf c, huruf d, huruf f, dan/atau huruf h untuk Penggunaan 
Secara Komersial dipidana dengan pidana penjara paling lama 3 (tiga) tahun 


dan/atau pidana denda paling banyak Rp500.000.000,00 (lima ratus juta rupiah). 
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Secara Komersial dipidana dengan pidana penjara paling lama 4 (empat) tahun 
dan/atau pidana denda paling banyak Rp1.000.000.000,00 (satu miliar rupiah). 


Setiap Orang yang memenuhi unsur sebagaimana dimaksud pada ayat (3) yang 
dilakukan dalam bentuk pembajakan, dipidana dengan pidana penjara paling lama 
10 (sepuluh) tahun dan/atau pidana denda paling banyak Rp4.000.000.000,00 
(empat miliar rupiah). 
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KATA PENGANTAR 


Perkembangan dunia IT yang semakin pesat merupakan salah satu pemicu dari 
perkembangan basis data. Kini seluruh universitas negeri maupun swasta di negeri 
ini, yaitu fakultas ilmu komputer, telah menjadikan mata kuliah basis data dan hal-hal 
yang berhubungan dengan basis data sebagai salah satu mata kuliah wajib mereka. 
Oleh karena itu, penulis menghaturkan buku “Database Design" -Case Study All 
In One sebagai dukungan penulis terhadap kemajuan bangsa dan negeri Indonesia 
tercinta ini. 


Buku ini ditujukan kepada para mahasiswa yang mengambil mata kuliah 
Perancangan Basis Data khususnya, serta masyarakat Indonesia yang berminat 
mempelajari basis data umumnya. Selain itu juga, ditujukan pula bagi kita yang 
akan dan tengah berkecimpung dalam dunia IT, baik dalam bidang programming 
maupun dalam bidang basis data, yang memiliki tekad sungguh-sungguh akan 
mempelajari bagaimana menganalisis dan merancang basis data yang benar dan 


baik. 


Penyajian materi diberikan secara jelas dan terperinci disertai dengan berbagai 
contoh kasus nyata sehari-hari. Dalam setiap bab diberikan contoh-contoh latihan 
dan diakhiri dengan sebuah kuis yang dapat membantu Anda untuk lebih memahami 
ulasan yang telah disajikan. 

Pembahasan dalam buku ini mencakup beberapa topik mengenai Teori Singkat 
Perancangan Basis Data, Teknik Pengumpulan Data, Analisis Sistem, Perancangan 
Basis Data, Implementasi, Contoh Kasus-Kasus, dan Source Code. 

Penulis juga tak lupa mengucapkan terima kasih yang sedalam-dalamnya kepada 
pihak-pihak yang telah mendukung penulis dengan sepenuh hati, antara lain: 
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sehingga penulis dapat menyelesaikan buku ini 


2. Papa (Alm.), Mama, Indrayati dan Herman JK., Indrajana S.E. dan Kang Lie 
Cing beserta ke dua anaknya Garry dan Kenny, dan Indrayeti. 


3. Eddy Widjaja, S.E., yang selama ini banyak mendukung dalam doa, daya, 
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BAR 


O1 


Pengantar Basis Data 


Siapakah yang berkata pada dirinya sendiri bahwa perancangan basis data 
itu sangat sulit dimengerti, apalagi dikerjakan oleh Anda yang pernah 
sedikit atau belum pernah sama sekali belajar tentang basis data? 
Sebelum menjawab pertanyaan tersebut, ada baiknya kita memper- 
lengkapi diri kita masing-masing dengan beberapa teori singkat mengenai 
perancangan basis data. 


Pada bab ini kita akan mempelajari hal-hal yang berhubungan dengan 
cara mencari buku-buku tentang perancangan basis data. Ini ada 
kaitannya dengan studi kepustakaan tentunya. Kemudian akan dijelaskan 
juga beberapa teknik pengumpulan data, selanjutnya tentang normalisasi, 
entity relationship diagram, dan terakhir, bagaimana merancang interaksi 
manusia dengan komputer. 


11 Studi Kepustakaan 


Metode ini dilakukan dengan cara mengumpulkan, membaca, dan mem- 
pelajari data-data yang ada dari berbagai media, seperti buku-buku, hasil 
karya tulis, jurnal-jurnal penelitian, atau artikel-artikel dari internet yang 
berhubungan dengan masalah yang dibahas. Jadi, kita akan mencari buku- 
buku yang ada hubungannya dengan perancangan basis data, penjualan, 
persediaan, dan pembelian. Pencarian dapat dilakukan via internet, con- 
tohnya dengan bertanya pada paman google (www.google.com), pergi 
ke perpustakaan, atau pergi ke toko buku. 
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Gambar 1.1 Layar-layar www.google.com 


1.2 Teknik Pengumpulan Data 


Istilah asing teknik pengumpulan data adalah fact finding technigues. Fact 
Finding adalah proses formal menggunakan teknik, seperti wawancara, 
observasi, kuesioner, dokumentasi, dan riset untuk mengumpulkan fakta 
tentang sistem, kebutuhan, dan pilihan. 

Setiap tahapan dalam siklus hidup basis data membutuhkan teknik pen- 
carian fakta. 


Tabel 1.1 Contoh Hubungan Tahapan Siklus Hidup Basis Data 
dengan Teknik Pencarian Fakta 


Tahapan Siklus Hidup Contoh Data Contoh Dokumentasi 
Basis Data yang dihasilkan 
Perencanaan Basis Tujuan dan sasaran projek basis Statemen misi dan sasaran 

Data data. sistem basis data. 
Definisi Sistem Deskripsi pandangan user yang Definisi lingkup dan batasan 


meliputi peranan pekerjaan atau aplikasi basis data. 


area bisnis aplikasi. Nana Ban 
Definisi user mengenai view 


yang mendukung mereka. 
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Kebutuhan- Kebutuhan user akan view dan Spesifikasi berbagai user 
kebutuhan spesifikasi sistem yang mencakup | dan kebutuhan sistem. 
pengumpulan dan kebutuhan kinerja dan keamanan. 

analisa 

Perancangan basis User memberikan respons untuk Konseptual dan Logikal 

data memeriksa kembali desain logika desain basis data seperti ER, 

basis data dan fungsi-fungsi yang kamus data, dan skema 
berhubungan dengan target relasional. 
DBMS. 

Rancangan fisikal basis data. 

Perancangan aplikasi User memberikan respons untuk Meliputi deskripsi program 

memeriksa desain user interface. dan user interface. 

Pemilihan DBMS Fungsi-fungsi yang berhubungan Berbagai evaluasi dan 

dengan target DBMS. rekomendasi DBMS. 

Prototipe User memberikan respons Perubahan berbagai 

mengenai prototipe. kebutuhan user dan 
spesifikasi sistem. 

Implementasi Fungsi-fungsi yang berhubungan 

dengan target DBMS. 
Konversi Data dan Format data sekarang. 
Loading : 

Kemampuan impor data. 

Pengujian Hasil pengujian. Strategi pengujian yang 
digunakan dan analisa hasil 
pengujian. 

Pemeliharaan Pengujian hasil kinerja. Manual user. 

Optional 
(Opa | Perubahan atau penambahan Analisa hasil kinerja. 
berbagai kebutuhan user dan 
Aan Perubahan berbagai 
' kebutuhan user dan 
spesifikasi sistem. 


Ada 5 teknik pencarian fakta yang digunakan: 


e Menguji dokumentasi 


Uji dokumentasi bermanfaat jika kita sedang berusaha mendalami 


kebutuhan basis data yang akan datang. 


Tabel 1.2 Contoh Menguji D 


okumentasi 


Tujuan Dokumentasi 


Contoh Dokumentasi 


Deskripsi masalah dan kebutuhan Memo intern 


menjelaskan 


al, email, dan keluhan karyawan 


basis data atau pelanggan saat rapat, serta dokumen yang 


berbagai masalah. 
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Pemeriksaan kembali kinerja dan berbagai 


laporan. 
Deskripsi bagian perusahaan yang Struktur organisasi, statemen misi, dan rencana 
dapat menimbulkan masalah strategi perusahaan. 


Tugas dan deskripsi pekerjaan. 


Contoh-contoh formulir dan laporan yang masih 
manual. 


Contoh-contoh formulir dan laporan yang telah 
terkomputerisasi. 


Deskripsi sistem sekarang Diagram aliran data dan bentuk-bentuk diagram 
lainnya. 


Kamus data. 
Perancangan sistem basis data. 


Dokumentasi program. 


Manual user atau pelatihan. 


e Wawancara 


Teknik ini paling sering digunakan dan sangat berguna dibandingkan 
teknik-teknik pencarian data lainnya. Terdapat 2 jenis wawancara, yaitu: 


1. Wawancara tidak terstruktur 


Wawancara tidak terstruktur dilakukan jika tujuan wawancara 
bersifat umum dan memiliki sedikit pertanyaan yang bersifat spesifik. 
Pewancara mengharapkan orang yang sedang diwawancarai itu 
menyediakan suatu kerangka dan arah kepada pewawancara. 
Wawancara jenis ini banyak menimbulkan kehilangan fokus dan 
karena alasan itulah hasil wawancara ini tidak baik bagi analisa dan 
perancangan basis data. 


2. Wawancara terstruktur 


Pewawancara mempunyai banyak pertanyaan yang spesifik. Keber- 
hasilannya bergantung pada tanggapan orang yang sedang diwa- 
wancarai dan apakah pewawancara dapat mengarahkan pertanyaan 
tambahan secara langsung untuk memperoleh klarifikasi atau per- 
luasan. 


Ada dua jenis pertanyaan yang dapat diajukan, yaitu pertanyaan 
terbuka dan pertanyaan tertutup. Perbedaannya adalah pertanyaan 
terbuka memperbolehkan orang yang sedang diwawancarai untuk 
memberikan respons pada berbagai pertanyaan yang sesuai dengan 
apa yang terdapat pada pikiran orang yang sedang diwawancarai. 
Sedangkan pertanyaan tertutup membatasi jawaban pada pilihan 


tertentu, singkat, tan an, secara langsung. 
Pe Yes Fan tanggap: d us Ana com 9 
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Tabel 1.3 Keuntungan dan Kerugian Wawancara 


Keuntungan 


Kerugian 


Memperbolehkan orang yang sedang 
diwawancarai untuk menjawab dengan 
bebas dan secara terbuka ke pertanyaan 


Mahal dan sangat memakan waktu. Tidak 
praktis. 


Memperbolehkan orang yang sedang 
diwawancarai untuk merasakan bagian 
dari proyek 


Kesuksesan bergantung pada keterampilan 
komunikasi pewawancara. 


Memperbolehkan pewawancara untuk 
mengikuti komentar menarik yang dibuat 
oleh orang yang sedang diwawancarai 


Kesuksesan dapat bergantung pada 
kesediaan orang yang sedang diwawancarai 
untuk mengambil bagian dari wawancara. 


Memperbolehkan pewawancara 
menyesuaikan atau mengulang kata yang 
dipertanyakan ke pewawancara 


Memperbolehkan pewawancara untuk 
mengamati bahasa tubuh orang yang 
sedang diwawancarai 


e Observasi 


Pengamatan adalah salah satu teknik pencarian data yang paling efektif 


untuk pemahaman suatu sistem. 


Tabel 1.4 Keuntungan dan Kerugian Observasi 


Keuntungan 


Kerugian 


Memperbolehkan kebenaran fakta dan 
data untuk diperiksa. 


Orang-orang dapat mengetahui atau tidak 
mengetahui ketika mereka sedang diamati. 
Jika mereka mengetahui sedang diamati, maka 
mereka dapat melakukan suatu hal yang 
berbeda. 


Pengamat dapat melihat secara nyata, 
apa yang dilaksanakan. 


Dapat ketinggalan pengamatan ketika 
terdapat perbedaan tingkat kesulitan dan 
jumlah pekerjaan dalam satu periode. 


Pengamat dapat memperoleh gambaran 
data suatu lingkungan fisik dari suatu 
tugas. 


Beberapa tugas tidak dapat selalu dilakukan 
cara yang sama di mana mereka diamati. 


Relatif murah. 


Dapat menjadi tidak praktis. 


Pengamat dapat melakukan pengukuran 
kerja. 
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e Riset 


Riset aplikasi dan masalah, jurnal komputer, buku petunjuk, dan 
internet seperti bulletin board adalah sumber informasi yang baik dan 
dapat menyediakan informasi mengenai bagaimana orang lain telah 


memecahkan masalah. 


Tabel 1.5 Keuntungan dan Kerugian Riset 


Keuntungan 


Kerugian 


Dapat menghemat waktu jika solusi 
telah ada. 


Memakan waktu lama. 


Dapat melihat bagaimana orang lain 
telah memecahkan permasalahan 
serupa atau menjumpai kebutuhan 
serupa. 


Memerlukan akses ke sumber informasi yang 
sesuai dengan masalah. 


Menyimpan hasil riset terbaru. 


Tidak dapat memecahkan masalah karena 
masalah tidak didokumentasikan pada tempat 
dengan baik. 


e Kuesioner 


Adalah teknik pencarian data dengan melakukan survei melalui daftar 


pertanyaan. 


Terdapat 2 jenis pertanyaan dalam kuesioner, yaitu: 


1. Free format 


Memberikan kebebasan responden untuk menjawab pertanyaan. 


2. Fix format. 


Memerlukan tanggapan spesifik dari individu. Dengan apa pun 
pertanyaan, responden harus memilih jawaban yang tersedia. 


Tabel 1.6 Keuntungan dan Kerugian Kuesioner 


Keuntungan 


Kerugian 


Orang-orang dapat melengkapi dan 
mengembalikan daftar pertanyaan 
dengan nyaman. 


Jumlah responden rendah, mungkin hanya 54X 
sampai 104. 


Relatif murah untuk mengumpulkan 
data dari sejumlah besar orang-orang. 


Daftar pertanyaan dapat dikembalikan tidak 
lengkap. 


Orang-orang lebih mungkin untuk 
menyediakan fakta nyata sebagai 


tanggapan yang dijaga kerahasiaannya. 


Tidak ada kesempatan untuk menyesuaikan 
atau mengulang apa yang telah ditafsirkan 
keliru. 


Tangapan dapat dibuat tabel dan 
dianalisa secara cepat. 


Tidak dapat mengamati dan meneliti bahasa 
tubuh responden. 


Versi Pdf 


Perlu waktu untuk membuat daftar 
pertanyaan. 
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1.3 Normalisasi 


Normalisasi adalah suatu teknik dengan pendekatan bottom-up yang diguna- 
kan untuk membantu mengidentifikasikan hubungan. Dimulai dari menguji 
hubungan, yaitu functional dependencies antara atribut. Pengertian lainnya 
adalah suatu teknik yang menghasilkan sekumpulan hubungan dengan sifat- 
sifat yang diinginkan dan memenuhi kebutuhan pada perusahaan. 


Tujuan Normalisasi 


Tujuan utama normalisasi adalah mengidentifikasikan kesesuaian hubungan 
yang mendukung data untuk memenuhi kebutuhan perusahaan. Adapun 
karekteristik hubungan tersebut mencakup: 


e Minimal jumlah atribut yang diperlukan untuk mendukung kebutuhan 
perusahaan. 


e Atribut dengan hubungan logika yang menjelaskan mengenai 
functional dependencies. 


e Minimal duplikasi untuk tiap atribut. 


Peranan Normalisasi dalam Perancangan Basis Data 


Normalisasi adalah suatu teknik formal yang dapat digunakan dalam 
perancangan basis data. Peranan normalisasi dalam hal ini adalah dalam 
penggunaan pendekatan bottom-up dan teknik validasi. Teknik validasi digu- 
nakan untuk memeriksa, apakah struktur relasi yang dihasilkan oleh ER 
modeling itu baik atau tidak baik. Anda dapat melihat lebih jelas lagi pada 
gambar berikut. 


Sumber Data 
Pendekatan 
User-User Top-Down 
Contoh : ER Model 
Spesifikasi 
«| Kebutuhan 
berbagai user 
Desain Normalisasi untuk 
Form Relasi Pendekatan? Teknik validasi 
atau 
Laporan 
Pendekatan 1 
Data Dictionary 
dan Pendekatan 


— | Data Model Perusahaan | ——— Bottom-Up 
Contoh : Normalisasi 


Gambar 1.2 Reranan: Ngrmalisasi/dalam Peyancangan Basis Data 
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Di sini terlihat sumber data terdiri atas user-user, spesikasi kebutuhan ber- 
bagai user, berbagai form atau laporan, data dictionary, dan data model 
perusahaan. Kemudian terdapat pendekatan top-down dan bottom-up, di 
mana pendekatan tersebut nantinya menghasilkan desain relasi. Lalu peranan 
normalisasi pada bottom-up dan teknik validasi. 
Terdapat enam bentuk normal yang biasa digunakan, yaitu: 
e First Normal Form (1NF) atau Normalisasi Tingkat 1 
e Second Normal Form (2NF) atau Normalisasi Tingkat 2 
e Third Normal Form (3NF) atau Normalisasi Tingkat 3 
e Boyce-Codd Normal Form (BCNF) 
e Four Normal Form (4NF) 
e Five Normal Form (5NF) 


Sumber Data 


Mengubah atribute ke format tabel 


Menghilangkan pengulangan grup 


4 Menghilangkan partial dependencies 


Menghilangkan fransifinie dependencies 


Gambar 1.3 Diagram Proses Normalisasi 


Proses Normalisasi 
Beberapa hal yang perlu diperhatikan dalam proses normalisasi adalah: 


e Suatu teknik formal untuk menganalisa relasi berdasarkan primary key 
dan functional dependencies antar-atribut. 


e Dieksekusi dalam beberapa langkah. Setiap langkah mengacu ke 
bentuk normal tertentu, sesuai dengan sifat yang dimilikinya. 

e Setelah normalisasi diproses, relasi menjadi secara bertahap lebih 
terbatas atau kuat mengenai bentuk formatnya dan juga mengurangi 


tindakan update YAPG ANAMAN ya di ipusnas.com 
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Gambar 1.4 Hubungan antara Normal Forms 


Unnormalized Form (UNF) 
Merupakan suatu tabel yang berisikan satu atau lebih grup yang berulang. 


Membuat tabel yang unnormalized, yaitu dengan memindahkan data dari 
sumber informasi. 


Contoh: nota penjualan yang disimpan ke dalam format tabel dengan baris 
dan kolom. 

First Normal Form (1NF) 

Merupakan sebuah relasi di mana setiap baris dan kolom berisikan satu dan 
hanya satu nilai. 


Proses UNF ke 1NF 


Tentukan satu atau kumpulan atribut sebagai kunci untuk tabel 

unnormalized. 

Identifikasikan grup yang berulang dalam tabel unnormalized yang 

berulang untuk kunci atribut. 

Hapus grup yang berulang dengan cara: 

Oo Masukkan data yang semestinya ke dalam kolom yang kosong 
pada baris yang berisikan data yang berulang (flattening the 
table). 

Oo Menggantikan data yang ada dengan menulis ulang dari kunci 
atribut yang sesungguhnya ke dalam relasi terpisah. 


Second Normal Form (2NF) 


Berdasarkan pada konsep full functional dependency, yaitu A dan B 
merupakan atribut sebuah relasi. B dikatakan fully dependent ter- 
hadap A jika B functionally dependent pada A tetapi tidak pada proper 
subset dari A. 

2NF merupakan sebuah relasi dalam 1NF dan setiap atribut non- 
primary-key bersifat fully functionally dependent pada primary key. 
1NF ke 2NF 

Oo Identifikasikan primary key untuk relasi 1NF 


fo IdentifikasikanJuncfignal de pendsncies,dalam relasi 
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o Jika terdapat partial dependencies terhadap primary key, maka 
hapus dengan menempatkan dalam relasi yang baru bersama 
dengan salinan determinannya. 


Third Normal Form (3NF) 


Berdasarkan pada konsep transitive dependency, yaitu suatu kondisi 

di mana A, B, dan C merupakan atribut sebuah relasi, maka A — B 

dan B — C, maka transitively dependent pada A melalui B. (Jika A 

tidak functionally dependent pada B atau C.) 

3 NF adalah sebuah relasi dalam 1NF dan 2NF, di mana tidak 

terdapat atribut non primaty key yang bersifat transitively dependent 

pada primary key. 

2NF ke 3NF 

Oo Identifikasikan primary key dalam relasi 2NF. 

o Identifikasikan functional dependencies dalam relasi. 

o Jika terdapat transitive dependencies terhadap primary key, 
hapus dengan menempatkannya dalam relasi yang baru ber- 
sama dengan salinan determinannya. 


Boyce-codd Normal Form (BCNF) 


Berdasarkan pada functional dependencies yang dimasukkan ke 
dalam hitungan seluruh candidate key dalam suatu relasi. Bagaimana 
pun BCNF juga memiliki batasan-batasan tambahan disamakan 
dengan definisi umum dari 3NF. 


Suatu relasi dikatakan BCNF, jika dan hanya jika setiap determinan 
merupakan candidate key. 

Perbedaan antara 3NF dan BCNF yaitu untuk functional dependency 
A—bB, 3NF memungkinkan dependency ini dalam suatu relasi jika B 
adalah atribut primary key dan A bukan merupakan candidate key. 


Sedangkan BCNF menetapkan dengan jelas bahwa untuk depen- 
dency ini agar ditetapkan dalam relasi A, maka A harus merupakan 
candidate key. 


Setiap relasi dalam BCNF juga merupakan 3NF, tetapi relasi dalam 
3NF belum tentu termasuk ke dalam BCNF. 


Dalam BCNF kesalahan jarang sekali terjadi. Kesalahan dapat terjadi 
pada relasi yang: 

Oo Terdiri atas 2 atau lebih composite candidate key. 

o Candidate key overlap, sedikitnya satu atribut. 


Contoh Kasus Normalisasi (1NF - 3NF) 


Diperoleh kumpulan formulir-formulir penyewaan rumah. 
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Gambar 1.5 Formulir-Formulir Penyewaan Rumah 


Penulisan UNF Menggunakan Tabel 


an sn Im 


JI. Kebun Jeruk No. 


. Jakarta Barat O/1/2008 01/12/2008 


JI Gatot Subroto No. 


00, Jakarta 0110152009 01/06/2009 
JI Gatot Subroto No. 
Indrayeti 100, Jakarta 01/1/2008 01/12/2009 1,000,000 


. Kebun Jeruk No. 


, Jakarta Barat 01112007 01/12/2007 


. Sudirman No. 2, 


01/11/2008 01/12/2008 


Gambar 1.6 UNF Penyewa SewaRumah 


PPT 


Wahyu 
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Dari bentuk UNF di atas, terdapat pengulangan grup, yaitu: 


No Properti, Alamat Properti, Tgl Mulai Sewa, Tgl Akhir Sewa, 
Sewa Perbulan, No Pemilik, dan Nama Pemilik. 


Penulisan UNF dengan notasi 
SewaRumah - No Penyewa t Nama Penyewa # 


€No Properti t Alamat Properti t Tgl Mulai Sewa # Tgl Akhir Sewa 
t Sewa Perbulan # No Pemilik t Nama Pemilik ) 


UNF — 1NF Cara Pertama 


No. Penyewa | No. Properti | NamaPenyewa | Alamat Properti | Tgl Mulai Sewa | Tgl Akhir Sewa | Sewa PerBulan | No. Pemilik | Nama Pemilik 

Jl. Kebun Jeruk No. 
S0 PR1 Indrajani 1, Jakarta Barat 015112008 01/12/2008 500,000 (PP39 Matius 

Jl Gatot Subroto No, 
S001 PR4 Indrajani 100, Jakarta 0110112009 01/06/2009 1,000,000 |PP77 Wahyu 

JI Gatot Subroto No. 
5003 PR4 Indrayeti 100, Jakarta 015112008 01/12/2009 1,000,000 (PP77 Wahyu 
Jl. Kebun Jeruk No 
5003 PR! Indrayeti 1, Jakarta Barat 01/11 2007 01/12/2007 500,000 (PP Matius 
Jl. Sudirman No. 2, 
503 PR2 Indrayeti Bandung 01112008 01/12/2008 150,000 (PP Matius 


Gambar 1.7 1NF Cara Pertama 


Functional dependencies yang terdapat pada relasi SewaRumah adalah: 
Fd1 No Penyewa, No Properti 5 Tgl Mulai Sewa, Tgl Akhir Sewa 
(Primary Key) 

Fd2 No Penyewa » Nama Penyewa (Partial Dependency) 


Fd3 No Properti » Alamat Properti, Sewa PerBulan, No Pemilik, 
Nama Pemilik (Partial Dependency) 


Fd4 No Pemilik 5 Nama Pemilik (Transitive Dependency) 


Fd5 No Penyewa, Tgl Mulai Sewa 5 No Properti, Alamat Properti, 
Tgl Akhir Sewa, Sewa PerBulan, No Pemilik, Nama Pemilik 
(Candidate Key) 


Fd6 No Properti, Tgl Mulai Sewa 5 No Penyewa, Nama Penyewa, 
Tgl Akhir Sewa (Candidate Key) 


Tujuan kita menggunakan functional dependencies adalah untuk menen- 
tukan candidate key bagi relasi SewaRumah berupa composite key, yaitu: 


No Penyewa#No Properti, 
No PenyewatTgl Mulai Sewa, 
No Properti#Tgl Mulai Sewa. 
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Akhirnya dipilih No PenyewatNo Properti sebagai primary key untuk 
relasi SewaRumah. 


Relasi SewaRumah dapat didefinisikan sebagai berikut: 


Penyewa SewaRumah  - No Penyewa ”t& No Properti 
Nama Penyewa # Alamat Properti 
Tgl Mulai Sewa # Tgl Akhir Sewa 
Sewa PerBulan  # No Pemilik 
Nama Pemilik 


444 


UNF 5 1INF Cara Kedua 
Penyewa - No Penyewa # Nama Penyewa 


SewaRumah - No Penyewa # No Properti # Alamat Properti 4 
Tgl Mulai Sewa # Tgl Akhir Sewa t Sewa PerBulan 
t No Pemilik - Nama Pemilik 


Penyewa 
No. Penyewa | Nama Penyewa 
S001 Indrajani 
5003 Indrayeti 
SewaRumah 
No. Penyewa | No. Properti | Alamat Properti | Tgl Mulai Sewa | Tgl Akhir Sewa | SewaPerBulan | No. Pemilik | Nama Pemilik 
. Kebun Jeruk 
No. 1, Jakarta 
S001 PRT Barat 011200 111 22008 500,000 (PP39 Matius 
Jl Gatot Subroto 
S001 PR4 No. 100, Jakarta 0110112009 110612009 1,000,000 (PP77 Wahyu 
Gatot Subroto 
5003 PR4 No. 100, Jakarta 01/1120 111 22009 1,000,000 (PP77 Wahyu 
Jl. Kebun Jeruk 
No. 1, Jakarta 
5003 PR! Barat O1/ 112007 111 22007 500,000 (PP99 Matius 
Jl. Sudirman No. 
$003 PR2 2, Bandung 01/20 111 22008 750,000 (PP99 Matius 
Gambar 1.8 1NF Cara Kedua 
1NF D 2NF 


Masih ingat dengan Functional Dependencies pada 1NF? Kita tetap meng- 
gunakannya dalam 2NF dengan memeriksa bagian mana yang merupakan 
partial dependency pada primary key. 
FD1 No Penyewa, No Properti 5 Tgl Mulai Sewa, Tgl Akhir Sewa 
(Primary Key) 
FD2 No Penyewa D Nama Penyewa (Partial Dependency) 
FD3 No Properti 5 Alamat Properti, Sewa PerBulan, No Pemilik, 
Nama Pemilik (Partial Dependency) 
FD4 No Pemilik 5 Nama Pemilik (Transitive Dependency) 
FD5 No Penyewa, Tgl Mulai Sewa 5 No Properti, Alamat Properti, 
Tgl Akhir Sewa, Sewa PerBulan, No Pemilik, Nama Pemilik 
(Candidate Key) 
FD6 No Properti, Tgl Mulai Sewa 5 No Penyewa, Nama Penyewa, 


Tgl Akhir Sewg(kapgdidala K9y) di ipusnas.com 
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